# Pipelined ARM Processor

Computer Architecture (CIE 439)

Mahmoud thabet 202000328 Beshoy malak 201800613 Youssef Youssef 201901047

# modules used:

- ALU.sv
- ARM.sv
- CondCheck.sv
- Controller.sv
- DataPath.sv
- Testbench.sv
- Top.sv
- Mux2.sv
- Mux3.sv

- Flopenrc.sv
- Floprc.sv
- Hazard.sv
- Imem.sv
- Regfile.sv
- Dmem.sv
- Eqcmp.sv
- Flopenr.sv
- Extend.sv

| PROGRAM             | ; COMMENTS       | HEX CODE |  |  |
|---------------------|------------------|----------|--|--|
| MAIN SUB RO, R15, R | R15 ;R0=0        | E04F000F |  |  |
| ADD R2, R0, #5      | ;R2 =5           | E2802005 |  |  |
| ADD R3, R0, #12     | ;R3 =12          | E280300C |  |  |
| SUB R7, R3, #9      | ;R7 =3           | E2437009 |  |  |
| ORR R4, R7, R2      | ;R4 =3 OR 5 =7   | E1874002 |  |  |
| AND R5, R3, R4      | ;R5 =12 AND 7 =4 | E0035004 |  |  |

```
ADD R5, R5, R4 ; R5 = 4 + 7 = 11 E0855004
SUBS R8, R7, R2 ; R8=3-5=-2, set Flags E0578002
ADDLTR7, R5, #1
                 ;R7 = 11 + 1 = 12 B2857001
SUB R7, R7, R2
                ;R7 = 12 - 5 = 7
                               E0477002
                ;mem[12+84] = 7 E5837054
STR R7, [R3, #84]
                 ;R2 = mem[96] = 7 E5902060
LDR R2, [R0, #96]
                  ;R12=114+7=121 E282C072
ADD R12, R2, #114
```

BIC R3, R12, R7 ; R3 =  $121 \& \sim 7 = 120$  E1CC3007

EOR R5, R3, R12 ; R5 = 120 ^121 = 1 E023500C

#### PCWRITE:

ADD R15, R15, #0 E28FF000

ADD R4, R0, R0 E2898005

ADD R5, R0, R0 E0805000

ADD R12, R4, R5 E084C005

```
B END ;always taken EA000001

ADD R2, R0, #13 ;shouldn't happen E280200D

ADD R2, R0, #10 ;shouldn't happen E280200A

END STR R2, [R0, #100] ;mem[100]=7 E5802064
```

# Simulation results

#### SUB R0, R15, R15



#### ADD R2, R0, #5; R2 = 5



### ADD R3, R0, #12 ; R3 = 12



#### SUB R7, R3, #9; R7 = 3 (Data dependency: solved by data forwarding)





#### ADD R5, R5, R4 ; R5 = 4 + 7 = 11 E0855004 (Data forwarding)



#### SUBS R8, R7, R2; R8=3-5=-2, set Flags E0578002 (n flag =1)





#### LDR R2, [R0, #96]; R2 = mem[96] = 7 E5902060



#### Full simulation



#### Full simulation

|                                  | Write to P | C        |          | e :      | ,        | Un Cond. |          |                | STR      | ,        |          |          |
|----------------------------------|------------|----------|----------|----------|----------|----------|----------|----------------|----------|----------|----------|----------|
| /testbench/dut/arm/dp/clk        | Wille to F |          |          |          |          | Brandh   | 厂        |                | 3111     | $\Box$   |          |          |
| /testbench/dut/arm/PCF           | 00000044   |          |          | 00000048 | 0000004c | 00000050 | 00000054 | 00000058       | 0000005c | 00000060 | 00000064 |          |
| /testbench/dut/arm/dp/RA1D       | 0          |          |          |          |          | 4        | f        | 0              |          |          | -        | -        |
| /testbench/dut/arm/dp/RA2D       | 0          |          |          |          |          | 5        | 1        | d              | 0        | 2        |          | <u> </u> |
| /testbench/dut/arm/ALUOutM       | 00000001   | 00000048 | 00000000 |          |          |          |          | 00000007       | 0000005c | 0000000d | 00000000 | 00000064 |
| /testbench/dut/arm/ALUControlE   | 0          | 2        |          |          |          | 0        |          |                |          | 2        | 0        | <u> </u> |
| /testbench/dut/arm/BranchTakenE  |            |          |          |          |          |          |          |                |          |          |          |          |
| /testbench/dut/arm/ALUFlagsE     | 0          | 4        |          |          |          |          | 0        |                |          | 4        | 0        | <u> </u> |
| /testbench/dut/arm/ForwardAE     | 0          |          |          |          |          |          |          |                |          |          |          |          |
| /testbench/dut/arm/ForwardBE     | 0          |          |          |          |          |          | 2        | 0              | 2        |          |          |          |
| /testbench/dut/arm/StallF        |            |          |          |          |          |          |          |                |          |          |          | <u> </u> |
| /testbench/dut/arm/StallD        |            |          |          |          |          |          |          |                |          |          |          |          |
| /testbench/dut/arm/FlushD        |            |          |          |          |          |          |          |                |          |          |          | _        |
| /testbench/dut/arm/FlushE        |            | 16       |          |          |          |          |          |                |          |          |          |          |
| /testbench/dut/arm/PCSrcW        |            |          |          |          |          |          |          |                |          |          |          |          |
| /testbench/dut/arm/MemtoRegW     |            |          |          |          |          |          |          |                |          | 1        |          |          |
| /testbench/dut/arm/WriteDataM    | 00000079   | 00000000 |          |          |          |          |          |                |          |          | 00000000 | 00000007 |
| /testbench/dut/arm/ReadDataM     | e04f000f   | e0805000 | e04f000f |          |          |          |          | e2802005       | e5802064 | e2437009 | e04f000f | <u> </u> |
| /testbench/dut/arm/dp/ALUOutW    | 00000078   | 00000001 | 00000048 | 00000000 |          |          |          |                | 00000007 | 0000005c | 0000000d | 00000000 |
| /testbench/dut/arm/dp/ALUResultE | -          | 00000000 |          |          |          |          | 00000007 | 0000005c       | 0000000d | 00000000 | 00000064 |          |
| 03 03 03 14 550                  | PC + 8     | 0+0      |          |          |          |          | R2 = 7   | Branch Address | S        |          |          | ]        |
|                                  |            |          |          |          |          |          |          |                |          |          |          |          |

# THANK YOU!